<!DOCTYPE html>
<html lang="zh-cn">
    <head>
        <meta charset="UTF-8">
        <title>更新页面</title>
        <link rel="stylesheet" href="/app/admin/component/pear/css/pear.css" />
        <link rel="stylesheet" href="/app/admin/component/jsoneditor/css/jsoneditor.css" />
        <link rel="stylesheet" href="/app/admin/admin/css/reset.css" />
        
    </head>
    <body>

        <form class="layui-form">

            <div class="mainBox">
                <div class="main-container mr-5">

<!--                    <div class="layui-form-item">-->
<!--                        <label class="layui-form-label required">状态:</label>-->
<!--                        <div class="layui-input-block">-->
<!--                            <input type="checkbox" id="status" lay-filter="status" required lay-skin="switch" />-->
<!--                            <input type="text" style="display:none" name="status" value="1" required />-->
<!--                        </div>-->
<!--                    </div>-->
                    
                    <div class="layui-form-item">
                        <label class="layui-form-label required">服务器类别</label>
                        <div class="layui-input-block">
                            <div name="type_id" id="type_id" required value="" ></div>
                        </div>
                    </div>
                    
                    <div class="layui-form-item">
                        <label class="layui-form-label required">渠道</label>
                        <div class="layui-input-block">
                            <div name="type" id="type" lay-filter="typeFilter" required value="" ></div>
                        </div>
                    </div>
                    
                    <div class="layui-form-item">
                        <label class="layui-form-label required">开启多端口</label>
                        <div class="layui-input-block">
                            <div name="multi_port_status" id="multi_port_status" required value="" ></div>
                        </div>
                    </div>

                    <div class="layui-form-item">
                        <label class="layui-form-label">sk5端口</label>
                        <div class="layui-input-block">
                            <textarea name="multi_port" placeholder="请输入sk5端口,例如 80-1000,会随机取80到1000范围内的端口" class="layui-textarea"></textarea>
                        </div>
                    </div>

                    <div class="layui-form-item">
                        <label class="layui-form-label">http端口</label>
                        <div class="layui-input-block">
                            <textarea name="domain_port" placeholder="请输入http端口" class="layui-textarea"></textarea>
                        </div>
                    </div>
                    
                    <div class="layui-form-item">
                        <label class="layui-form-label required">服务器名</label>
                        <div class="layui-input-block">
                            <input type="text" name="name" value="" required lay-verify="required" placeholder="请输入服务器名" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item">
                        <label class="layui-form-label required">域名</label>
                        <div class="layui-input-block">
                            <input type="text" name="domain" value="" required lay-verify="required" placeholder="请输入http" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item">
                        <label class="layui-form-label required">ip</label>
                        <div class="layui-input-block">
                            <input type="text" name="ip" value="" required lay-verify="required" placeholder="请输入ip" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item">
                        <label class="layui-form-label required">端口</label>
                        <div class="layui-input-block">
                            <input type="text" name="port" value="" required lay-verify="required" placeholder="请输入端口" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-account" style="display: none">
                        <label class="layui-form-label">账号</label>
                        <div class="layui-input-block">
                            <input type="text" name="account" value="" placeholder="请输入账号" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-password" style="display: none">
                        <label class="layui-form-label">密码</label>
                        <div class="layui-input-block">
                            <input type="text" name="password_new" value="" placeholder="请输入密码" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-command_add" style="display: none">
                        <label class="layui-form-label">新增命令</label>
                        <div class="layui-input-block">
                            <textarea name="command_add" placeholder="执行命令(仅SSH渠道的使用):例如echo '账号 密码'>> /etc/opt/ss5/ss5,passwd 系统会自动替换 账号/密码关键字" class="layui-textarea"></textarea>
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-command_del" style="display: none">
                        <label class="layui-form-label">删除命令</label>
                        <div class="layui-input-block">
                            <textarea name="command_del" placeholder="执行命令(仅SSH渠道的使用):例如sed -i '/账号/d' /etc/opt/ss5/ss5,passwd 系统会自动替换 账号/密码关键字" class="layui-textarea"></textarea>
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-line_type" style="display: none">
                        <label class="layui-form-label">线路类型</label>
                        <div class="layui-input-block">
                            <div name="line_type" id="line_type" value="" ></div>
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-key" style="display: none">
                        <label class="layui-form-label">key</label>
                        <div class="layui-input-block">
                            <input type="text" name="key" value="0" placeholder="请输入key" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-link_url_number" style="display: none">
                        <label class="layui-form-label">链接数</label>
                        <div class="layui-input-block">
                            <input type="number" name="link_url_number" value="0" placeholder="请输入链接数" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-bandwidth_up" style="display: none">
                        <label class="layui-form-label">带宽上行(限制)</label>
                        <div class="layui-input-block">
                            <input type="text" name="bandwidth_up" value="0" placeholder="请输入带宽上行(限制)" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-bandwidth_down" style="display: none">
                        <label class="layui-form-label">带宽下行(限制)</label>
                        <div class="layui-input-block">
                            <input type="text" name="bandwidth_down" value="0" placeholder="请输入带宽下行(限制)" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item" id="c-max_limit" style="display: none">
                        <label class="layui-form-label">最大ip限制</label>
                        <div class="layui-input-block">
                            <input type="text" name="max_limit" value="" placeholder="请输入最大ip限制" class="layui-input">
                        </div>
                    </div>
                    
                    <div class="layui-form-item">
                        <label class="layui-form-label">备注</label>
                        <div class="layui-input-block">
                            <textarea name="content" placeholder="请输入备注" class="layui-textarea"></textarea>
                        </div>
                    </div>
                    
                </div>
            </div>

            <div class="bottom">
                <div class="button-container">
                    <button type="submit" class="pear-btn pear-btn-primary pear-btn-md" lay-submit="" lay-filter="save">
                        提交
                    </button>
                    <button type="reset" class="pear-btn pear-btn-md">
                        重置
                    </button>
                </div>
            </div>
            
        </form>

        <script src="/app/admin/component/layui/layui.js?v=2.8.12"></script>
        <script src="/app/admin/component/pear/pear.js"></script>
        <script src="/app/admin/component/jsoneditor/jsoneditor.js"></script>
        <script src="/app/admin/admin/js/permission.js"></script>
        
        <script>

            // 相关接口
            const PRIMARY_KEY = "id";
            const SELECT_API = "/app/admin/v1-server/select" + location.search;
            const UPDATE_API = "/app/admin/v1-server/update";

            // 获取数据库记录
            layui.use(["form", "util", "popup"], function () {
                let $ = layui.$;
                $.ajax({
                    url: SELECT_API,
                    dataType: "json",
                    success: function (res) {
                        
                        // 给表单初始化数据
                        layui.each(res.data[0], function (key, value) {
                            let obj = $('*[name="'+key+'"]');
                            if (key === "password") {
                                obj.attr("placeholder", "不更新密码请留空");
                                return;
                            }
                            if (typeof obj[0] === "undefined" || !obj[0].nodeName) return;
                            if (obj[0].nodeName.toLowerCase() === "textarea") {
                                obj.val(value);
                            } else {
                                obj.attr("value", value);
                                obj[0].value = value;
                            }

                            if(key == 'type'){
                                if(value == 1){
                                    layui.$("#c-account").show();
                                    layui.$("#c-password").show();
                                    layui.$("#c-command_add").show();
                                    layui.$("#c-command_del").show();
                                }
                                if(value == 2){
                                    layui.$("#c-account").show();
                                    layui.$("#c-password").show();
                                    layui.$("#c-link_url_number").show();
                                    layui.$("#c-bandwidth_down").show();
                                    layui.$("#c-max_limit").show();
                                }
                                if(value == 3){
                                    layui.$("#c-line_type").show();
                                    layui.$("#c-key").show();
                                    layui.$("#c-link_url_number").show();
                                    layui.$("#c-bandwidth_up").show();
                                    layui.$("#c-bandwidth_down").show();
                                    layui.$("#c-max_limit").show();
                                }
                            }
                        });
                        
                        // // 字段 状态:0=禁用,1=正常 status
                        // layui.use(["form"], function() {
                        //     layui.$("#status").attr("checked", layui.$('input[name="status"]').val() != 0);
                        //     layui.form.render();
                        //     layui.form.on("switch(status)", function(data) {
                        //         layui.$('input[name="status"]').val(this.checked ? 1 : 0);
                        //     });
                        // })
                        
                        // 字段 服务器类别ID type_id
                        layui.use(["jquery", "xmSelect", "popup"], function() {
                            layui.$.ajax({
                                url: "/app/admin/v1-server-type/select2?format=tree",
                                data:{
                                    field: PRIMARY_KEY,
                                    order: 'asc'
                                },
                                dataType: "json",
                                success: function (res) {
                                    let value = layui.$("#type_id").attr("value");
                                    let initValue = value ? value.split(",") : [];
                                    layui.xmSelect.render({
                                        el: "#type_id",
                                        name: "type_id",
                                        initValue: initValue,
                                        filterable: true,
                                        data: res.data, 
                                        model: {"icon":"hidden","label":{"type":"text"}},
                                        clickClose: true,
                                        radio: true,
                                        layVerify: "required",
                                    });
                                    if (res.code) {
                                        layui.popup.failure(res.msg);
                                    }
                                }
                            });
                        });

                        // 字段 渠道:1=SSH,2=CCproxyweb,3=接口 type
                        layui.use(["jquery", "xmSelect","form"], function() {
                            layui.$.ajax({
                                url: "/app/admin/dict/getNew/get_channel_list",
                                dataType: "json",
                                success: function (res) {
                                    let value = layui.$("#type").attr("value");
                                    let initValue = value ? value.split(",") : [];
                                    layui.xmSelect.render({
                                        el: "#type",
                                        name: "type",
                                        initValue: initValue,
                                        filterable: true,
                                        data: res.data,
                                        value: "",
                                        model: {"icon":"hidden","label":{"type":"text"}},
                                        clickClose: true,
                                        radio: true,
                                        layVerify: "required",
                                        on: function(data){ // data 是返回的数据对象，包括选中的值等
                                            console.log(data,'data'); // 打印选中的数据
                                            let value = data.change[0]['value'];

                                            layui.$("#c-account").hide();
                                            layui.$("#c-password").hide();
                                            layui.$("#c-command_add").hide();
                                            layui.$("#c-command_del").hide();
                                            layui.$("#c-line_type").hide();
                                            layui.$("#c-key").hide();
                                            layui.$("#c-link_url_number").hide();
                                            layui.$("#c-bandwidth_up").hide();
                                            layui.$("#c-bandwidth_down").hide();
                                            layui.$("#c-max_limit").hide();
                                            if(value == 1){
                                                layui.$("#c-account").show();
                                                layui.$("#c-password").show();
                                                layui.$("#c-command_add").show();
                                                layui.$("#c-command_del").show();
                                            }
                                            if(value == 2){
                                                layui.$("#c-account").show();
                                                layui.$("#c-password").show();
                                                layui.$("#c-link_url_number").show();
                                                layui.$("#c-bandwidth_down").show();
                                                layui.$("#c-max_limit").show();
                                            }
                                            if(value == 3){
                                                layui.$("#c-line_type").show();
                                                layui.$("#c-key").show();
                                                layui.$("#c-link_url_number").show();
                                                layui.$("#c-bandwidth_up").show();
                                                layui.$("#c-bandwidth_down").show();
                                                layui.$("#c-max_limit").show();
                                            }
                                        }
                                    });
                                    if (res.code) {
                                        layui.popup.failure(res.msg);
                                    }
                                }
                            });
                        });

                        // 字段 开启多端口:0=关闭,1=开启 multi_port_status
                        layui.use(["jquery", "xmSelect"], function() {
                            layui.$.ajax({
                                url: "/app/admin/dict/getNew/get_open_off_list",
                                dataType: "json",
                                success: function (res) {
                                    let value = layui.$("#multi_port_status").attr("value");
                                    let initValue = value ? value.split(",") : [];
                                    layui.xmSelect.render({
                                        el: "#multi_port_status",
                                        name: "multi_port_status",
                                        initValue: initValue,
                                        filterable: true,
                                        data: res.data,
                                        value: "",
                                        model: {"icon":"hidden","label":{"type":"text"}},
                                        clickClose: true,
                                        radio: true,
                                        layVerify: "required",
                                    });
                                    if (res.code) {
                                        layui.popup.failure(res.msg);
                                    }
                                }
                            });
                        });

                        // 字段 线路类型 line_type
                        layui.use(["jquery", "xmSelect", "popup"], function() {
                            layui.$.ajax({
                                url: "/app/admin/dict/getNew/get_line_list",
                                dataType: "json",
                                success: function (res) {
                                    let value = layui.$("#line_type").attr("value");
                                    let initValue = value ? value.split(",") : [];
                                    layui.xmSelect.render({
                                        el: "#line_type",
                                        name: "line_type",
                                        initValue: initValue,
                                        filterable: true,
                                        data: res.data,
                                        value: "",
                                        model: {"icon":"hidden","label":{"type":"text"}},
                                        clickClose: true,
                                        radio: true,
                                    });
                                    if (res.code) {
                                        layui.popup.failure(res.msg);
                                    }
                                }
                            });
                        });


                        // ajax返回失败
                        if (res.code) {
                            layui.popup.failure(res.msg);
                        }
                        
                    }
                });
            });

            //提交事件
            layui.use(["form", "popup"], function () {
                // 字段验证允许为空
                layui.form.verify({
                    phone: [/(^$)|^1\d{10}$/, "请输入正确的手机号"],
                    email: [/(^$)|^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/, "邮箱格式不正确"],
                    url: [/(^$)|(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/, "链接格式不正确"],
                    number: [/(^$)|^\d+$/,'只能填写数字'],
                    date: [/(^$)|^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/, "日期格式不正确"],
                    identity: [/(^$)|(^\d{15}$)|(^\d{17}(x|X|\d)$)/, "请输入正确的身份证号"]
                });
                layui.form.on("submit(save)", function (data) {
                    data.field[PRIMARY_KEY] = layui.url().search[PRIMARY_KEY];
                    layui.$.ajax({
                        url: UPDATE_API,
                        type: "POST",
                        dateType: "json",
                        data: data.field,
                        success: function (res) {
                            if (res.code) {
                                return layui.popup.failure(res.msg);
                            }
                            return layui.popup.success("操作成功", function () {
                                parent.refreshTable();
                                parent.layer.close(parent.layer.getFrameIndex(window.name));
                            });
                        }
                    });
                    return false;
                });
            });

        </script>

    </body>

</html>
